Skip to content

Conversation

@DOD-101
Copy link
Collaborator

@DOD-101 DOD-101 commented Jan 5, 2025

I have ported Tokonights extra-generation system to work for nordic.nvim.

I have adjusted the code to make it more well suited for nordic.nvim, mainly simplifying it, since nordic.nvim doesn't have mutliple flavors, but reversing this to work for multiple flavors in the future wouldn't be a significant challange.

Why?

This would allow for easier creation of additional platforms, as well as help reduce inconsistencies between the different handwritten themes.

To-Do:

The one problem currently is that we would need to find a way to convert the hex color values to work for iTerm2 and Konsole since they use other formats.

However, I don't think this will be a significant blocker.

  • Port the generation system
  • Port all existing themes to the new system
    • Create conversion functions for iTerm2 and Konsole
  • Add CI to update /platforms on each addition / change of one of the template files
  • Update docs

Note on Licensing

Since Tokyonight is licensed under Apache License 2.0 we need to make sure we are in compliance with their License. I have added a note to the top of platforms/init.lua, but I am not sure if this is all that we require.

It might be a good idea to add a NOTICE file.

@DOD-101
Copy link
Collaborator Author

DOD-101 commented Jan 5, 2025

I'm more than willing to implement all the steps listed above, but I would first like to get this approved, before I take the time to implement the rest.

@5-pebbles
Copy link
Collaborator

5-pebbles commented Jan 5, 2025

I am in support of this PR, I think it would make updating the color palate much easier and help keep thing in sync. It would also make vetting new extras faster (no more checking hex codes).

I think the simplest approach for CI would be to just add the generation to the docs_and_format workflow.

If I remember right, we used to have color conversion stuff in utils but then I deleted it all... I will see if I can fish that back up.

Edit: It looks like we still have some of them. I am not near a device with a working nvim config, but something like this should work:

local U = require("nordic.utils")
local r, g, b = U.hex_to_rgb(hex)
return string.format("%d,%d,%d", r, g, b)

I would define that function in the individual themes, because I doubt we will find iTerm2's system anywhere else.

What do you think @AlexvZyl?

@5-pebbles 5-pebbles requested a review from AlexvZyl January 5, 2025 19:06
5-pebbles
5-pebbles previously approved these changes Jan 5, 2025
Copy link
Collaborator

@5-pebbles 5-pebbles left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That looks great!

@AlexvZyl
Copy link
Owner

Yeah this is very nice, thanks @DOD-101.

Copy link
Collaborator

@5-pebbles 5-pebbles left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am noticing we have a lot of colors, in the platforms, that aren't used anywhere else... If you can keep those close to their original value, but of course, use values actually in our palette.

Also, thanks for doing this, I didn't realize what a mess it was until now.

-- stylua: ignore
---@type table<string, {ext: string, url:string, subdir?: string}>
M.platforms = {
-- fish = { ext = "theme", url = "https://fishshell.com/docs/current/index.html" },
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this supposed to be here?

@AlexvZyl AlexvZyl removed their request for review January 27, 2025 07:56
@AlexvZyl AlexvZyl added the Enhancement New feature, request or suggestion label Jan 27, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Enhancement New feature, request or suggestion

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants